"""
Copyright (c) 2022 Huawei Technologies Co.,Ltd.

openGauss is licensed under Mulan PSL v2.
You can use this software according to the terms and conditions of the Mulan PSL v2.
You may obtain a copy of Mulan PSL v2 at:

          http://license.coscl.org.cn/MulanPSL2

THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
See the Mulan PSL v2 for more details.
"""
"""
Case Type   : 系统内部使用工具
Case Name   : 普通用户执行gs_upgradechk export -p port -F markdown导出的报告指定markdown格式
Create At   : 2023/08/02
@zou_jialiang0505318640
Description :
    1.执行gs_upgradechk export -p port -F markdown
    2.执行gs_upgradechk export -p port -F md
Expect      :
    1.报告导出成功
    2.报告导出成功
History     :
"""

import unittest
import os
from testcase.utils.CommonSH import CommonSH
from testcase.utils.Common import Common
from testcase.utils.Logger import Logger
from yat.test import Node
from yat.test import macro

LOG = Logger()


class ToolsTestCase(unittest.TestCase):
    def setUp(self):
        self.common = Common()
        self.commonsh = CommonSH('PrimaryDbUser')
        self.user_node = Node('PrimaryDbUser')
        LOG.info("---SetUp：检查数据库状态是否正常---")
        status = self.commonsh.get_db_cluster_status()
        LOG.info(status)
        self.assertTrue("Degraded" in status or "Normal" in status)

    def test_system_internal_tools(self):
        LOG.info(f"----{os.path.basename(__file__)} start----")
        LOG.info("---step1：gs_upgradechk export -p port -F markdown\
                            expect:导出成功---")
        cmd1 = f"gs_upgradechk export -p {self.user_node.db_port} -F markdown"
        LOG.info(cmd1)
        result1 = self.user_node.sh(f"source {macro.DB_ENV_PATH};"
                                       f"{cmd1}").result()
        LOG.info(result1)

        self.vmp1 = result1.split('。')[-1].split(':')[1]
        LOG.info(self.vmp1)

        self.assertIn(f"基准校验地图导出完成:{self.vmp1}", result1)

        LOG.info("---step2：gs_upgradechk export -p port -F md\
                              expect:导出成功---")
        cmd2 = f"gs_upgradechk export -p {self.user_node.db_port} -F md"
        LOG.info(cmd2)
        result2 = self.user_node.sh(f"source {macro.DB_ENV_PATH};"
                                   f"{cmd2}").result()
        LOG.info(result2)

        self.vmp2 = result2.split('。')[-1].split(':')[1]
        LOG.info(self.vmp2)

        self.assertIn(f"基准校验地图导出完成:{self.vmp2}", result2)


    def tearDown(self):
        LOG.info('--------无需清理环境--------')
        status = self.commonsh.get_db_cluster_status("detail")
        LOG.info(status)
        self.assertTrue("Degraded" in status or "Normal" in status)
        LOG.info(f"------{os.path.basename(__file__)} end------")